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(57) Abstract: Home-networked client devices are connected to a host system that assigns independent Internet addresses to the 
client devices using a home gateway device that is connected to the client devices through a network. The home gateway device 
which may be physically located in a personal residence, generally includes a communication device to communicate with the host 
system over a single communication tunnel established between the home gateway device and the host system. The home gateway 
device also may include a PPPoE access concentrator, an L2TP access concentrator, a network address translation module and/or a 
DHCP module. The client devices are typically connected to the home gateway device via a network and the client devices communi- 
cate with the host system through the home gateway device using individual communication sessions over the single communication 
tunnel. & 
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HOME-NETWORKING 

CROSS REFERENCE TO RELATED APPLICATIONS 
This application claims priority from U.S. Provisional Application No. 60/189,977, 
filed March 17, 2000, and titled "Home-networking," which is incorporated by reference. 

TECHNICAL FIELD 
This invention relates to connecting multiple home-networked client devices to a host 

system. 

BACKGROUND 

An increasing number of households have more than one personal computing device. 
As the number of personal computing devices within the home increases, there is a need and 
consumer demand for intercomiectivity among these devices and for connectivity between 
these devices and host systems located outside of the home. For instance, in a household that 
includes more than one personal computing device, it may be desirable to enable connection 
between each device and an Internet Service Provider (ISP). It is possible to simply network 
several devices together in the home to enable interconnectivity among the devices and to 
enable a connection to outside host systems. However, with the devices networked together, 
the host system may recognize the entire network as a single device rather than recognizing 
the individual devices within the network or users of those individual devices. 

Failing to recognize and thus distinguish the individual devices or individual users of 
the devices may prevent the host system from enforcing or enabling preferences and features 
otherwise distinguishable among individual devices or users, such as parental access 
controls. Similarly, without recognition of or distinction among devices and their users, the 
individual client devices and users of the client devices may not be able to access and receive 
back from the host certain host-maintained preferences, such as personal identification 
settings, personal web pages, account infoimation, wallet information, and financial 
infoxrmation. 
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SUMMARY 

la one general aspect, home-networked client devices are connected to a host system 
that assigns independent Internet addresses to the home-networked client devices using a 
home gateway device that is connected to the home-networked client devices through a 
network The home gateway device, which may be physically located in a personal 
residence, generally includes a communication device to communicate with the host system 
over a single communication tunnel established between the home gateway device and the 
host system. The home-networked client devices communicate with the host system through 
the home gateway device over the single communication tunnel. The system configuration 
enables the host system to establish individual communication sessions with the home- 
networked client devices over the single communication tunnel and to assign independent 
Internet addresses to the home-networked client devices. 

Implementations may include one or more of the following features. For example, 
the home gateway device and the home-networked client devices may be physically located 
in a personal residence. The personal residence may include a single family dwelling. The 
home-networked client devices may include wireless client devices that may be connected to 
the home gateway device through a wireless network such that the wireless client devices 
may operate outside of the personal residence. 

The home-networked client devices may establish simultaneous individual 
communication sessions with the host system over the single communication tunnel. Each 
home-networked client device may be assigned an independent Internet address by the host 
system, which may include an Internet Service Provider. 

The home gateway device may communicate with the home-networked client devices 
using a first protocol and may communicate with the host system using a second protocol. 
Hie first protocol and the second protocol may be the same protocol, or the second protocol 
may differ from the first protocol. 

The home gateway device may include one or more modules that are structured and 
arranged to convert between the first protocol and the second protocol. The first protocol 
may include PPPoE and the second protocol may include L2TP. The home-networked client 
devices may be PPP enabled. The home gateway device may emulate a PPPoE access 
concentrator and an L2TP access concentrator. The communication device may include a 
modem, such as a cable modem, a satellite modem, or a DSL modem. 
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The home-networked client devices may include client devices having computer 
software that enables the client devices to interface with the home gateway and to 
communicate with the host system through the home gateway device, such that the host 
system is able to recognize independent client devices. The independent client devices may 
5 be recognized by the host system through the use of unique identifiers assigned to each of the 
client devices by the host system during the established communication session. The unique 
identifiers may be unique to the client devices and/or to users of Hie client devices. A unique 
identifier may include an independent Internet address, and also may include a unique 
identifier for a user of a client device combined with an independent Internet address 
1 o assigned to the client device. In addition, a unique identifier may include a screen name for a 
user of the client devices. 

When the user has a unique identifier that is combined with the independent Internet 
address assigned by the host system to the client device, the user may be enabled to access 
individual information maintained by the host system for that particular user. Additionally, 
1 5 the host system may be enabled to enforce host-based parental or other controls. Individual 
information maintained by the host system may include wallet information, calendar 
information, and personalized web page information. 

The home gateway device may include a personal computer and/or a server. The 
network between the home gateway device and the home-networked client devices may 
. 20 include a wired network, a wireless network, and/or any combination of a wired and a 
wireless network. The network may include an Ethernet network. 

In one implementation, the home gateway device may include a dynamic host 
configuration protocol module and an L2TP access concentrator. The home-networked client 
devices may communicate with the home gateway device using the dynamic host 
25 configuration protocol module. The home gateway device and the home-networked client 
devices may communicate over the network using DHCP, and the home-networked client 
devices may be assigned a single address that is used in communications with the home 
gateway device and the host system. The single communication tunnel established between 
the home gateway device and the host system may be established over a broadband network. 
30 The dynamic host configuration module may be configured to facilitate communications 

between the host system and the home-networked client devices to enable the host system to 
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enforce host-based parental controls. The assignment of unique addresses to the home- 
networked client devices may be performed upon bootup of the client devices. 

In one implementation, the home gateway device may include a network address 
translation module. The network address translation module may include a port-based or an 
address-based network address translation module. The home gateway device may 
communicate with the home-networked client devices using TCP/IP, and with the host 
system using L2TP. The network address translation module may interface with the home- 
networked client devices and the host system to route communications between the host 
system to the home-networked client devices by translating independent Internet addresses 
assigned by the host system to the home-networked client devices and local addresses 
belonging to the home-networked client devices that are used on the network between the 
home gateway device and the home-networked client devices. The multiple home-networked 
client devices are typically recognized by the host system as independent client devices 
through the use of unique identifiers. 

These general and specific aspects may be implemented using a system, a method, or 
a computer program, or any combination of systems, methods, and computer programs. 

Other features and advantages will be apparent from the description and drawings, 
and from the claims. 

DESCRIPTION OF DRAWINGS 
Fig. 1 is a block diagram of a home networking system. 
Fig. 2 is a block diagram of a client device of the system of Fig. 1. 
Fig. 3 is a block diagram of a host system of the system of Fig. L 
Fig. 4 is a block diagram of an implementation of the home networking system of 

Fig. 1, 

Fig. 5 is a block diagram of the home networking system of Fig. 1 illustrating one 
protocol implementation. 

Fig. 6 is a block diagram of the components which may be included in a client device 
of the system of Fig. 1. 

Fig. 7 is block diagram of the components which may be included in a home gateway 
device of the system of Fig. 1 . 

Fig. 8 is a more detailed block diagram of the home gateway device of Fig. 7. 
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Fig. 9a is a flow chart of a process used to enable a home network. 
Fig. 9b is a flow chart of a process used to enable a home network. 
Figs. lOa-lOd are block diagrams of a protocol enabling communication between the 
components of the home networking system. 

Fig. 1 1 is a block diagram of the home gateway device including a NAT module. 
Fig. 12 is a block diagram of the home networking system using a NAT module. 
Fig. 13 is a block diagram of the home gateway device including a DHCP module. 
Fig. 14 is a flow chart of a process used to enable a home network. 
Like reference symbols in the various drawings indicate like elements. 

DETAILED DESCRIPTION 

Referring to Fig. 1, a home networking system 100 typically includes multiple home- 
networked client devices 105 ("client devices") connected through a network 1 10 to each 
other and to a home gateway device 115. The home gateway device 115 typically connects 
to the host system 130 through a communication device 120 over commimication links 125. 
The home networking system 100 enables the client devices 105 to communicate with the 
host system 130 through the home gateway device 115 using the single communication 
device 120. The client devices 105, the home gateway device 115, and tlie communication 
device 120 may be physically located in a personal residence, as indicated by the dashed 
lines shown in Fig. 1 . 

The home networking system 100 enables the host system 130 to assign unique 
identifiers (e.g., independent Internet addresses) to each of the client devices 105 through the 
home gateway device 115 over a single communication link 125 established between the 
home gateway device 115 and the host system 130. The home networking system 100 also 
enables the client devices 105 to access information maintained by the host system 130 for a 
particular client device 105 or a particular individual user of the client devices 105. In 
addition, the home networking system 100 enables the host system 130 to maintain and 
enforce individual preferences associated with a particular client device 105 or a user of the 
client devices 105 through using the host-assigned unique identifiers and/or some 
combination of the host-assigned unique identifiers with other identifiers (e.g., login name, 
account number, screen name, and password). 
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The client devices 105 and the home gateway device 115 typically are located in a 
physical place that enables the home gateway device 115 to network with the client devices 
105, In one implementation, for example, the home gateway device 1 15 is physically located 
in a personal residence (e.g., a single-family dwelling, a house, a townhouse, an apartment, 
or a condominium). The client devices 105 may be physically located such that 
communications over the network 110 with the home gateway device 1 15 are enabled and 
maintained. For instance, when the home gateway device 1 15 is physically located in a 
personal residence, the client devices 105 also may be physically located in the personal 
.residence. However, the location of the home gateway device 1 15 in the personal residence 
does not preclude one or more of the client devices 105 from being networked to the home 
gateway device 1 15 from a remote location. Nor does it preclude use of one or more of the 
client devices 105 from outside of the personal residence or communication by those devices 
with the host system 130 through the home gateway device 115. For instance, the client 
devices 105 may include one or more portable computing devices that may be taken outside 
of the personal residence and still remain connected to the home gateway device 115 located 
within the personal residence through a wireless network 110. 

The client devices 105 may include one or more general-purpose computers (e.g., 
personal computers), one or more special-purpose computers (e.g., devices specifically 
programmed to communicate with the home gateway device 115 and/or the host system 130), 
or a combination of one or more general-purpose computers and one or more special-purpose 
computers. Other examples of client devices 105 include a workstation, a server, an 
appliance (e.g., a refrigerator, a microwave, and an oven), an intelligent household device 
(e.g., a thermostat, a security system, anHVAC system, and a stereo system), a device, a 
component, other physical or virtual equipment, or some combination of these elements 
capable of responding to and executing instructions within the system architecture. 

. Referring to Fig. 2, components of a client device 205 are shown to illustrate one 
possible implementation of the client devices 105 of Fig. L The client device 205 may 
include a general-purpose computer 240 having an internal or external storage 242 for storing 
data and programs such as an operating system 244 (e.g., DOS, Windows™, Windows 95™, 
Windows 98™, Windows 2000™, WindowsNT™, OS\2 and Linitx) and one or more 
application programs. Examples of application programs include authoring applications 246 
(e.g., wordprocessing, database programs, spreadsheet programs, and graphic programs) 
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capable of generating documents or other electronic content; client applications 248 (e.g:, 
AOL client, COMPUSERVE client, AIM client, AOL TV client, and ISP client) capable of 
coimnunicating with other computer users, accessing various computer resources, and 
viewing, creating, or otherwise manipulating electronic content; and browser applications 
250 (e.g., Netscape's Navigator and Microsoft's Internet Explorer) capable of rendering 
standard Internet content. 

The general-purpose computer 240 also includes a central processing unit (CPU) 252 
for executing instuctions in response to commands from a client controller. In one 
implementation, the client controller includes one or more of the application programs 
installed on the internal or external storage 242 of the general-purpose computer 240. In 
another implementation, the client controller includes application programs externally stored 
in and executed by one or more devices external to the general-purpose computer 240. 

The general-purpose computer 240 typically will include a communication device 
254 for sending and receiving data. One example of the communication device 254 is a 
modem. Other examples include a transceiver, a set-top box, a communication card, an 
xDSL modem (e.g., ADSL, CDSL, DSL Lite, HDSL, IDSL, RADSL, SDSL, UDSL, and 
VDSL), a cable modem, a satellite modem, a satellite dish, and an antenna, or another 
network adapter capable of transmitting and receiving data over a network through a wired or 
wireless data pathway. 

In addition to or as an alternative to the communication device 254, the general- 
purpose computer 240 may include a network interface card (NIC) 256, which may provide a 
dedicated, full-time connection to a network. Examples of NIC types include ISA, EISA, 
PCMCIA, PCI, Sbus, MCA, NuBus, and USB, which may support various types of 
networks, buses and connectivities. 

The general-purpose computer 240 also may include a television (TV) tuner 258 for 
receiving television programming in the form of broadcast, satellite, and/or capable TV 
signals. As a result, the client devices 205 can selectively and/or simultaneously display 
network content received by the communication device 254 and television programming 
content received by the TV tuner 258. 

The general-purpose computer typically will include an input/output interface 260 to 
enable a wired or wireless connection to various peripheral devices. Examples of peripheral 
devices include, but are not limited to, a mouse 262, a mobile phone 264, a personal digital 
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assistant (PDA) 266, a keyboard 268, a display monitor 270 with or without a touch screen 
input, and/or a remote control 272 for receiving information from and rendering information 
to subscribers. Other examples may include voice recognition and synthesis devices (not 
shown). 

5 Although devices such as a mobile telephone 264, a PDA 266, and a TV remote 

control 272 may be considered peripheral with respect to the general-pufpose computer 240, 
in another implementation, such devices may themselves include the functionality of the 
general-purpose computer and may operate as a stand-alone client device 205. For example, 
the mobile phone 264 or the PDA 266 may include computing and networking capabilities, 

10 and may function as the client device 205. 

Referring again to Fig. 1, the client devices 105 typically are connected to one 
another and to the home gateway device 115 through a network 110, such as a Local Area 
Network (LAN). The network 110 may include a wired and/or a wireless network. For 
instance, one or more of the client devices 105 may be connected to the home gateway 

15 device 1 15 via a wired network 110 and, at the same time, one or more other client devices 
105 xnay be connected to the home gateway device 1 15 via a wireless network 110. 
Examples of types of networks 110 include a token ring, an Ethernet, a Fast Ethernet, a 
Gigabit Ethernet, HomePNA, and powerline networking. 

As mentioned above, the client devices 105 access and communicate with the host 

20 system 1 30 through the home gateway device 115. For example, the home gateway device 
115 may include a general-purpose computer (e.g., personal computer), or a special-purpose 
computer. Other examples of the home gateway device 115 may include a workstation, a 
server, a device, a component, other physical or virtual equipment, or some combination 
thereof capable of responding to and executing instructions in the manner defined to function 

25 as the home gateway device. 

The home gateway device 115 may include internal or external storage for storing 
data and programs as described above with respect to the client devices 105, such as an 
operating system, application programs, client applications, and browser applications. In 
addition to these programs and applications, the home gateway device 115 may include one 

30 or more special modules and programs (e.g., a Network Address Translation module, a 

PPPoE Access Concentrator module, an L2TP Access Concentrator module, a dialer module, 
and a DHCP module) or combinations of these modules and programs designed to allow the 
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home gateway device 115 to communicate with the client devices 105 over the network 110 
and to facilitate communications between the client devices 105 with the host system 130 
through the home gateway device 1 1 5. Additionally or alternatively, the home gateway 
device 115 may be embodied as part of a client device 105 with the functionality to perform 
as the home gateway device 115. 

The home gateway device 115 typically includes or has access to a communication 
device 120. Examples of the communication device 120 may include the communication 
devices described above with respect to the communication device 254 in Fig. 2. 
Additionally or alternatively, the home gateway device 115 typically includes a network 
interface card such as described above with respect to the network interface card 256 in Fig. 
2. 

The home gateway device 1 15 typically communicates with the host system 130 
through communication links 125. The communication links 125 typically include a delivery 
network making a direct or indirect communication between the home gateway device 115 
and the host system 130, irrespective of physical separation. Examples of a delivery network 
include the Internet, the World Wide Web, WANs, LANs, analog or digital wired and 
wireless telephone networks (e.g., PSTN, ISDN, and xDSL), radio, television, cable, satellite, 
and/or any other delivery mechanism for carrying data. 

Referring to Fig. 3, components of a host system 330 are shown to illustrate one 
possible implementation of the host system 130 of Fig. 1. The host system 330 typically 
includes one or more host devices 360. The host devices 360 may include hardware 
components and/or software components, such as one or more general-purpose computers 
(e.g., personal computers), one or more special-purpose computers (e.g., devices specifically 
programmed to communicate with the home gateway device 115 and/or the client devices 
105), or a combination of one or more general-purpose computers and one or more special- 
purpose computers. Other examples of host devices 360 include a workstation, a server, a 
component, a device, other physical or virtual equipment, or some combination of these 
elements that is capable of responding to and executing instructions within the system 
architecture. 

More specifically, a host device 360 within the host system 330 may include a login 
server for enabling access by subscribers and routing communications between other systems 
(e.g., client devices 105 and the home gateway device 1 15 from Fig. 1) and other elements of 
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the host system 330. The host system 330 also may include various host complexes such as 
an OSP ("Online Service Provider") host complex 370 and anIM ("Instant Messaging") host 
complex 380, To enable access to these host complexes by subscribers, the client devices 
(e.g., 105 from Fig. 1) and the home gateway device (e.g., 1 15 from Fig. 1) may include 
5 communication software such as an OSP client application and an IM client application. The 
OSP and IM communication software applications are designed to facilitate the subscriber's 
interactions with the respective services and, in particular, may provide access to some or all 
of the services available within the respective host complexes. For example, Instant 
Messaging allows a subscriber to use the IM client application to view whether particular 
10 subscribers ("buddies") are online, exchange instant messages with particular subscribers, 
participate in group chat rooms, trade files such as pictures, invitations or documents, find 
other subscribers with similar interests, get customized news and stock quotes, and search the 
Web. 

Typically, the OSP host complex 370 supports different services, such as email, 

15 discussion groups, chat, news services, and Internet access. The OSP host complex 370 
generally is designed with an architecture that enables the machines within the OSP host 
complex 370 to communicate with each other, and to employ certain protocols (i.e., 
standards, formats, conventions, rules, and structures) to enable the transfer of data. The 
OSP host complex 370 ordinarily employs one or more OSP protocols and custom dialing 

20 engines to enable access by selected client applications. The OSP host complex 370 may 
define one or more specific protocols for each service based on a common, underlying 
proprietary protocol. 

The IM host complex 380 may be independent of the OSP host complex 370, and 
may support instant messaging services irrespective of a subscriber's network or Internet 

25 access. Thus, the IM host complex 380 may be configured to allow subscribers to send and 
receive instant messages, whether or not they have access to any particular ISP. The IM host 
complex 380 may support associated services, such as admhiistrative matters, advertising, 
directory services, chat, and interest groups related to the instant messaging. The IM host 
complex 380 has an architecture that enables all of the machines within the IM host complex 

30 to communicate with each other. To transfer data, the IM host complex 380 employs one or 
more standard or exclusive IM protocols. 
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The host system 330 may include one or more gateways that connect and therefore 
link complexes, such as the OSP host complex gateway 375 and the IM host complex 
gateway 385. The OSP host complex gateway 375 and the IM host complex gateway 385 
may directly or indirectly link the OSP host complex 370 with the IM host complex 380 
5 through a wired or wireless pathway. Ordinarily, when used to facilitate a link between 
complexes, the OSP host complex gateway 375 and the IM host complex gateway 385 are 
privy to information regarding a protocol anticipated by a destination complex, which 
enables any necessary protocol conversion to be performed incident to the transfer of data 
from one complex to another. For instance, the OSP host complex 370 and IM host complex 

10 380 may use different protocols such that transferring data between the complexes requires 
protocol conversion by or at the request of the OSP host complex gateway 375 and/or the IM 
host complex gateway 385. 

In one implementation, the host system 130 may maintain information related to the 
client devices 105 or to a user of the client devices 105. For example, such information may 

1 5 include parental control settings, wallet settings, personal web pages, instant messaging user 
lists, and any other type of personal settings or features or information associated with a 
particular client device 105 or a user of client device 105. In this implementation, it may be 
important to enable recognition of or distinction between different client devices 105 and/or 
ixsers accessing the host system so that the stored information is not rendered useless, or 

20 worse yet, inaccurately applied. 

Fig. 4 shows several implementations and possible combinations of devices and 
systems used within the home networking system 420. The client devices 405, the network 
410, the home gateway device 415, the communication devices 420, the communication links 
425, and the host system 430 typically correspond to their respective elements 1 05, 1 1 0, 1 15, 

25 120, 125, and 130 illustrated in Fig. 1. The elements in Fig. 4, which have corresponding 

elements in Fig. 1, are not meant to limit the scope of the elements previously described with 
respect to Fig. 1, but instead are merely some possible examples of these elements. 

Examples of client devices 405 may include, but are not limited to, a personal 
computer with a Windows™ operating system 405a , a personal computer with a Linux™ 

30 based operating system 405b, a Macintosh™ personal computer 405c, a television set-top 
box 405d, a PDA 405e, and an intelligent home appliance 405f. As described above with 
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respect to Fig. 1, the client devices 405 are connected through a network 410 to the home 
gateway device 415. 

The home gateway device 415 typically includes a communication device 420. 
Examples of the communication device 420 may include a satellite modem 420a, an analog 
modem 420b, a cable modem 420c, and an xDSL modem 420d. The home gateway device 
415 uses the communication device 420 to communicate through communication links 425 
with the host system 430. The communication Imks 425 may include various types of 
communication delivery systems that correspond to the type of communication device 420 
being used. For example, if the home gateway device 415 includes a satellite modem 420a, 
then the communications from the client devices 405 and the home gateway device 415 may 
be delivered to the host system 430 using a satellite dish 425a and a satellite 425b. The 
analog modem 420b may use one of several communications links 425, such as the satellite 
dish 425a and satellite 425b, the Plain Old Telephone Service (POTS) 425c, and the Cable 
Modem Termination System (CMTS) 425d. The cable modem 420c typically uses the 
CMTS 425d to deliver and receive communications from the host system 430. The xDSL 
modem 420d typically delivers and receives communications with the host system 430 
through a Digital Subscriber Line Access Multiplexer (DSLAM) 425e and an Asynchronous 
Transfer Mode (ATM) network 425£ 

The home networking system 400 may use various protocols to communicate 
between the client devices 405 and the home gateway device 415 and between the home 
gateway device 415 and the host system 430. For example, a first protocol may be used to 
communicate between the client devices 405 and the home gateway device 415, and a second 
protocol may be used to communicate between the home gateway device 415 and the host 
system 430. In one implementation, the first protocol and the second protocol may be the 
same. In another implementation, the first protocol and the second protocol may be different. 
The home gateway device 415 may include different hardware and/or software modules to 
implement different home networking system protocols. Various implementations and 
alternatives to the home networking system architecture are discussed below, 

PPPoE 

Referring to Fig. 5, the elements 505, 510, 515, 520, 525, and 530 typically 
correspond to the respective elements 105, 110, 115, 120, 125, and 130 of Fig. 1 and to 
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respective elements 405, 410, 415, 420, 425, and 430 of Fig, 4. Iti one implementation, the 
client devices 505 communicate through, the network 510 with the home gateway device 515 
using Point-to-Point Protocol over Ethernet (PPPoE). The home gateway device 5 1 5 
communicates with the host system 530 through the communication device 520 over 
communication links 525. For communications between the client devices 505 and the host 
system 530, the home gateway device 515 strips off the "oE" header from the PPPoE traffic 
used by the client devices 505, encapsulates the PPP traffic in Layer Two Tunneling Protocol 
(L2TP), then encapsulates the L2TP traffic in User Datagram Protocol (TJDP), and passes on 
the encapsulated PPP communications to the host system 530. This architecture enables 
multiple client devices 505 to communicate simultaneously with the host system 530 over a 
single communication tunnel established between the home gateway device 515 and the host 
system 530 while allowing the host system 530 to recognize independent Internet addresses 
with respect to each of the client devices 505. This architecture also enables a one-to-one 
mapping of a PPPoE session to an L2TP session. 

Referring to Fig. 6, in one implementation, the client device 605 may include one or 
more hardware and/or software modules, such as, for example, a client application 602, a 
TCP/IP interface module 604, a TCP/TP protocol implementation module 606, a PPP protocol 
implementation module 608, a PPP WAN driver SHIM module 612, a PPPoE protocol 
module 613, a real-time operating system (OS) 614, a protocol interface module 616, a 
standard Ethernet device driver interface module 61 8, and a standard Ethernet hardware 
adapter 620. The client device may use one or more of these modules to facilitate 
communications with other devices (e.g., the home gateway device 515 and the host system 
530 through the home gateway device 515 from Fig. 5). 

For example, the client application 602 may generate a request to initiate 
communications with the home gateway device (e.g., 515 from Fig. 5) and send outbound 
traffic (e.g., TCP/IP traffic going from the client device 605 to the home gateway device 515 
from Fig. 5). The request may pass from the client application 602 through the TCP/IP 
interface module 604, which may allow for simultaneous support of multiple protocols 
between the client application level (e.g., User mode or Ring 3) and an operating system 
level (e.g., Kernel mode or Ring 0), and ultimately to the TCP/IP protocol implementation 
module 606. The TCP/IP protocol implementation module 606 typically operates in 
conjunction with the PPP protocol implementation module 608 and the PPP WAN driver 
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SHIM module 612 to prepare and encapsulate the traffic in a protocol (e.g., encapsulate the 
TCP/IP traffic in PPP). 

The real-time OS 614 may manage real-time interprocess communications between 
various protocols (e.g., between PPPoE and L2TP and between user and Kernel mode 
5 modules), including buffer management and task scheduling. The PPPoE protocol module 
613 may add a header (e.g., an Ethernet header and a PPPoE header) to the traffic (e.g., 
TCBTP traffic encapsulated in PPP) to enable the home gateway device (e.g., 515 from Fig. 
5) to identify the particular client device 605 from which the traffic is originating. Thus, the 
traffic may be considered PPPoE. More specifically, in one example, the header may include 

1 o address information learned during the PPPoE discovery stage, which is discussed hi more 

detail below, and may append the "oE" header to the PPP encapsulated traffic. The real-time 
OS 614 typically calls the protocol interface module 616, which is typically bound to a 
Network Interface Card (NIC) (e.g., 256 from Fig. 2) and allows for the exchange of traffic 
between the NIC and the PPPoE protocol module 613. The traffic then is typically 

15 communicated to the home gateway device using the NIC, the standard Ethernet driver 
module 618, and the Ethernet adapter 620. 

For inbound traffic (e.g., PPP traffic coming from the home gateway device to the 
client device 605), received traffic from the standard Ethernet driver module 618 is indicated 
to the protocol interface module 616. The PPPoE protocol module 613 receives the traffic 

20 from the protocol interface module 61 6 via the real-time OS 614. The PPPoE protocol 

module 613 strips off any header from the traffic (e.g., removing the "oE" header from the 
PPPoE traffic) and passes the traffic to the PPP WAN driver SHIM module 612. The PPP 
WAN driver SHIM module 612 then passes the traffic to the PPP protocol implementation 
module 608 for delivery to the TCP/IP protocol implementation module 606. The client 

25 application 602 receives traffic from the TCP/IP miplementation module 606 via the TCP/IP 
interface module 604. 

Referring to Fig. 7, in one implementation, the home gateway device 715 may include 
a PPPoE access concentrator 717, an L2TP access concentrator 719, and a dialer module 721. 
The home gateway device 715 uses L2TP to tunnel the PPP traffic from each client PPPoE 
30 session to the host system. A single L2TP tunnel is established between the home gateway 
device and the host system to carry multiple PPP sessions because L2TP provides a method 
to multiplex multiple PPP sessions within a single tunnel (e.g., multiple L2TP sessions). 
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Thus, in this implementation, a first protocol is used between the client devices and the home 
gateway device 715, and a second protocol is used between the home gateway device 715 
and the host system to enable individual communication sessions between the client devices 
and the host system. In particular, the first protocol includes PPPoE and the second protocol 
5 includes L2TP. The dialer module 721 may be configured with a unique identifier (e.g., a 
login name combined with a password) that enables the host system to identify the home 
gateway device 715. 

Fig. 8 shows a more detailed block diagram of an exemplary home gateway device 
815. In this implementation, the PPPoE access concentrator 817 and the L2TP access 

10 concentrator 819 include hardware and/or software which may be operated as user 
mode/Ring 3 applications. 

The home gateway device 815 includes the PPPoE access concentrator 817 that 
enables communications with the client devices (e.g., 505 from Fig. 5). The PPPoE access 
concentrator 817 is capable of handling multiple, simultaneous PPP sessions with the PPPoE 

15 enabled client devices 505. Enabling each client device with its own PPP session permits the 
client device to receive its own unique identifier from the host system. The unique identifier 
may include, for example, an Internet address. 

When the home gateway device 815 commxmicates with the client devices 505, a 
standard ethemet driver 823 is used to exchange Ethernet frames between the home gateway 

20 device 815 and the client devices 505. The home gateway device 815 employs a standard 

protocol driver 823 that, in conjunction with the real-time operating system (OS) 825, allows 
the exchange of Ethernet traffic from the client devices 505 with the PPPoE access 
concentrator 817. The protocol driver 823 binds to Ethernet driver 827 to facilitate the 
exchange of traffic between the home gateway device 815 and the PPPoE access 

25 concentrator 817. The real-time OS 825 typically provides the interprocess communication 
capability between protocol driver 823 and PPPoE access concentrator 817. When the home 
gateway device includes more than one Ethernet driver 827, the PPPoE access concentrator 
817 uses the PPPoE discovery phase to identify which particular Ethernet driver 823 will be 
used to exchange traffic with a particular client device 505. 

30 The L2TP access concentrator module 819 within the home gateway device 815 uses 

UDP over IP to exchange L2TP traffic with the host system (e.g., 530 from Fig. 5) using the 
standard TCP/IP module 829. When connectivity needs to be established with the host 
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system 530, the dialer module 821 establishes connectivity to the host system 530 prior to the 
exchange of L2TP traffic between the L2TP access concentrator module 819 and the host 
system 530. Additionally, the dialer module 821 may calculate the host system 530 address, 
allowing the home gateway device 815 the potential to add a static route to the host system 
5 530 in the home gateway device 815 routing table. This m,ay prevent a new default route 
from interfering with the tunnel traffic between the home gateway device 815 and the host 
system 530. The real-time OS 825 may be used to provide interprocess communications 
between the PPPoE access concentrator 817 and the L2TP access concentrator module 819. 
Additionally or alternatively, the PPPoE access concentrator 817 and the L2TP access 
1 o concentrator module 819 may be combined within the same module, as indicated by the 
dashed lines 840. 

Fig. 9a illustrates one implementation of a process for enabling communications 
between a client device and the host system, through the home gateway device. The client 
device typically initiates an action that indicates its desire to communicate with the host 

15 system, for example, by launching an application (e.g., a browser or a client application) or 
by sending a command and/or a request. 

It is determined whether communications are established between the client device 
and the home gateway device (step 901a). If communications are not already established 
between the client device and the home gateway device (step 901a), then the client device 

20 and the home gateway device establish communications (steps 901-905). The client device 
and the home gateway device may, for example, establish communications using PPPoE 
(steps 901-905). 

Once communications are established between the client device and the home 
gateway device (steps 901-905) or if communications between the client device and the 

25 home gateway device were already established (step 901a), then it is determined whether 

communications are established between Hie home gateway device and the host system (step 
907a). If communications are not already established between the home gateway device and 
the host system (step 907a), then the home gateway device activates the home gateway dialer 
module (steps 907 and 909). The home gateway device then establishes communications 

30 with the host using the home gateway dialer module (steps 911-915). The home gateway 
device may, for example, establish communications using L2TP by setting up an L2TP 
tunnel over which multiple, individual L2TP sessions may be .established. 

16 
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Once communications are established between the home gateway device and the host 
system (steps 911-915) or if communications between the home gateway device and the host 
system were already established (step 907a), then the home gateway device establishes a 
communication session for the client device to communicate with the host system (steps 917- 
5 925). The communication session may, for example, include an L2TP session created over 
the established L2TP tunnel. Thus, the client device and the host system are enabled to 
communicate over the established communication session (step 927). 

More particularly, one specific implementation of the process shown by Fig. 9a is 
described with respect to Fig. 9b. Referring to Fig. 9b, a client device initiates a 

1 o communication with the host system by initiating the PPPoE discovery phase. Discovery 
starts with a broadcast of the PPPoE Active Discovery Initiation (PADI) packet from the 
client device to the home gateway device (step 901). If the gateway device is present and the 
server software is running, the home gateway device responds with a directed ethernet frame 
containing a PPPoE Active Discovery Offer (PADO) packet (step 903). The client device 

1 5 typically responds to the PADO packet with a PPPoE Active Discovery Request (PADR) 

packet (i.e., a directed ethernet frame using the server's media access control (MAC) address 
as the destination address) (step 905). 

When the home gateway device receives the PADR packet, an L21P tunnel is needed 
to the host system to enable the client device to begin sending PPP traffic, which will end up 

20 being tunneled through the L2TP session to the host system. The L2TP tunnel typically is 
created between the home gateway device and an LNS, which is a component of the host 
system. When the home gateway device receives the PADR packet, a dialer module within 
the home gateway device is triggered to send a command to establish a connection with the 
host system (step 907). The connection type is based on the client device's configuration of 

25 the configurable home gateway dialer. For example, the home gateway dialer may support 
various types of connections such as, dial-up modem, xDSL, cable, satellite, and any other 
type of connection. One process of establishing connections using or through the home 
gateway dialer is discussed further below. 

Once the dialer is connected (step 909), the home gateway device begins sending 

30 messages to the host system to create the L2TP tunnel. The process of creating the L2TP 
tunnel begins with the Stait-Control-Request (SCCRQ) message (step 911). The LNS 
responds with a Start-Confrol-Connection-Reply (SCCRP) message (step 913). The SCCRP 
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message indicates the LNS is able to bring up and establish the L2TP tunnel. The tunnel 
establishment is complete when the home gateway device sends a Start-Control-Coixnection- 
Connected (SCCCN) message (step 915). 

At or about the same time that the home gateway device sends the SCCCN message, 
the home gateway device also sends a PPPoE Active Discovery Session-confirmation 
(PADS) message to the client device (step 917). The PADS message indicates to the client 
device that it may begin sending PPP traffic to the host system. When the home gateway 
device receives PPP traffic from the client device (step 919), the home gateway device opens 
an L2TP session across the L2TP tunnel that was just created between the home gateway 
device and the host system. 

The L2TP session is initiated when the home gateway device sends an incoming call 
request (ICRQ) (step 921). The LNS within the host system responds with an incoming call 
reply (ICRP) (step 923). Finally, the home gateway device completes the handshake by 
sending an incoming call connected (ICCN) message (step 925). At that point, PPP traffic is 
tunneled by the home gateway device for an end-to-end exchange between the client device 
and the host system (step 927). Thus, PPPoE is used to deliver the PPP traffic from the client 
device to the home gateway device. More particularly, the PPPoE traffic is sent to the 
PPPoE access concentrator (817 from Fig. 8) within the home gateway device (815 from Fig. 
8). The home gateway device 815 strips off the PPPoE header leaving the PPP traffic. The 
home gateway device 815 then replaces the PPPoE header with a valid L2TP session header 
so that the original PPP traffic is sent in the L2TP tunnel to the host system via the L2TP 
access concentrator (819 from Fig. 8). Multiple L2TP sessions may be established 
simultaneously over the same L2TP tunnel. 

Fig. 10a illustrates a more detailed discussion of protocols that may be used to enable 
communications between the client devices (not shown), the home gateway device 1015, and 
the host system 1030. After the client device initiates the PPP discovery phase with the 
home gateway device 1015, the home gateway device 1015 initiates communications with 
the host system 1030. The home gateway device 1015, as discussed above, may use a 
communication device 1020, such as a modem (e.g., analog modem or dial-up modem), a 
cable modem, a satellite modem, or a DSL modem, to communicate with the host system 
1030. The dialer module within the home gateway device 1015 (e.g., dialer module 821 of 
Fig. 8) initiates communications with host system 1030 by making a call to an L2TP enabled 

18 



WO 01/71977 



PCT/US01/08559 



POP ("Point of Presence"), which may or may not reside within the host system 1030. 
Specifically, the dialer module initiates a call with an L2TP access concentrator (LAC) 1032, 
which is located within the POP and which may or may not reside within the host system 
1030 (step 1000-1 of Fig. 10a). 
5 Referring to Fig. 1 0b, following the call from the dialer module to the LAC 1 032, 

PPP is typically partially negotiated through the dialer module's dial-up network connection 
to the LAC 1032 (step 1000-2 of Fig. 10b). The PPP Link Control Protocol (LCP) layer is 
negotiated and the process of authentication starts by communicating a login sequence from 
the home gateway device 1015 to the LAC 1032. 

10 Referring to Fig. 10c, the LAC 1032 notifies the L2TP Network Server (LNS) 1036, 

which typically is a component of the host system 1030, that a login sequence and 
authentication process has been initiated by the home gateway device 1015. The LAC 1032 
may conduct a radius lookup to identify a particular LNS with which to communicate. The 
LNS then restarts LCP negotiation with the dialer module (step 1 000~3a of Fig. 1 0c). After 

1 5 renegotiating LCP, as illustrated by Fig. 1 0c, the LNS 1 03 6 and the dialer module negotiate 
authentication and Internet Protocol Control Protocol (IPCP) (step 1000-3b of Fig. 10c). 

Referring to Fig. lOd, for the LNS 1036 to complete this PPP negotiation, the POP's 
LAC 1 032 first creates a tunnel 1 038, and then starts a session over that tunnel. Once the 
tunnel 1038 is established, the home gateway device 1015 creates its own tunnel to the LNS 

20 1036, as illustrated in Fig, lOd. As shown, an end-to-end PPP session 1040 is established 
between the home gateway device 1015 and the LNS 1036 which is over the LAC/LNS 
L2TP tunnel 1038. Thereafter, for each client device that requests connection to the host 
system 1030, the home gateway device 1015 will open a newL2TP session over its 
established tunnel 1040. 

25 During the connectivity process between the dialer module within the home gateway 

device 1015 and the host system 1030, the host system 1030 assigns the dialer module a 
unique identifier, such as an assigned Internet protocol address. The dialer module typically 
includes software code to perform this function. For instance, the dialer module may be 
configured with a unique identifier which allows the dialer module access to the host system 

30 1030 through an authentication process. The unique identifier may include a screen name 
and an associated password. 
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Network Address Translation 

Referring to Fig. 11, in another implementation, the home gateway device 1115 may 
include an L2TP access concentrator 1 1 19 to communicate with the host system, a Network 
Address Translator (NAT) module 1121 that facilitates communications with the client 
5 devices, and a TCP/IP module 1 123. The home gateway device 1 1 15, which includes the 
NAT module 1 121, enables the host system to assign independent Internet addresses 
associated with each home-networked client device over a single communication tunnel that 
is established between, the home gateway device and the host system, hi one implementation, 
the home gateway device 1115 uses the NAT module 1 121 to map the host-assigned 

10 addresses to local addresses associated with each client device. This enables the client 

devices or a user of the client devices to access individual information maintained by the host 
system. This also enables the host system to enforce host-based controls (e.g., parental 
controls) for each individual client device and/or a user of each client device. 

As described above, the home gateway device 1115 typically establishes a connection 

1 5 with the host system using the L2TP access concentrator 1119. The L2TP access 

concentrator 1119 establishes the L2TP tunnel with the LNS in the host system, as described 
above with respect to Figs. 10a- lOd. 

In one implementation, the home gateway device 1115 may assign the client devices 
local addresses to identify and facilitate individual communications between the home 

20 gateway device 1115 and the client devices. The home gateway device may include a 

Dynamic Host Configuration Protocol (DHCP) module 1 127, which may assign the local 
addresses (e.g., local IP addresses) to the client devices. The client devices typically include 
a DHCP client module (e.g., Windows™ DHCP), which may seek a local address from the 
home gateway device 1115 (e.g., at startup or at some other time). The DHCP module 1 127 

25 also may assign the home gateway device 1 1 1 5 as the default route for each client device. 

Additionally or alternatively, the client devices may be configured with manually 
assigned local addresses (e.g., static IP addresses) that are recognized by and made known to 
the home gateway device 1 1 15. The home gateway device 1115 functions to map the locally 
assigned addresses between the client devices and the home gateway device 1 1 15 to the host 

30 system assigned addresses between the host system and the client devices. In this maimer, 
the host system is capable of recognizing the individual client device that is communicating 
with the host system. 

20 
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Referring to Fig. 12, the client devices 1205 typically include software that enables 
generation of IP traffic from the client devices 1205 to an outside entity. The client device 
1205 attempts to communicate with the host system 1230. The attempt generates IP traffic 
from the client device 1205 to the host system 1230. Information included within the IP 
traffic typically includes a destination address specifying a location within the host system 
1230. The client device 1205 may be configured to route traffic destined for the host system 
1230 or traffic destined outside of the home local network 1210 to a default routing table. 
Thus, the traffic destined for the host system 1230 is sent to the home gateway device 1215, 
The home gateway device 1215 typically examines the traffic from the client devices 1205 
and monitors for traffic from a new source. When the home gateway device 1215 recognizes 
traffic destined for the host system 1230 from a new source, the home gateway device 1215 
establishes communications with the host system 1230, for example, by creating an L2TP 
tunnel with an LNS (not shown) and obtains an IP address for the home gateway device 
1215. In this manner, the home gateway device 1215 and the host system 1230 establish the 
L2TP tunnel over the communication links 1225. 

After the L2TP tunnel has been established, the home gateway device 1215 and the 
host system 1230 establish an L2TP session over the L2TP tunnel, which is associated with 
the client device 1205 requesting access to the host system 1230. Once the L2TP session is 
established, the host system 1230 assigns the home gateway device 1215 an IP address for 
that particular L2TP session. The home gateway device 1215 maps the host-assigned IP 
address to the client device 1205 local address, thus allowing communications between the 
client device 1205 and the host system 1230 to occur using an independent host-assigned 
Internet address. The home gateway device 1215 will continue mapping the Internet address 
provided by the host system 1230 to the client device's 1205 local address as long as the 
L2TP session remains connected. 

For example, as shown in Fig. 12, if the client device A 1205 has a local address of 
10.0.0.2 and the address assigned by host system 1205 to client device A is 10.2.114.13, then 
the home gateway device 1215 maps 10.0.0.2 with 10.2.1 14.13. From the client's 
perspective, the home gateway device 1215 replaces the source IP address from client device 
A (10.0.0.2) with a valid host-assigned address (10.2.114.13) for all of client device A's 1205 
outbound traffic. For inbound traffic, the home gateway device 1215 replaces the destination 
address (10.2.1 14.13) with (10.0.0.2) and then forwards the traffic on the network 1210 
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between the home gateway device 1215 and the client devices to client device A 1205. Thus, 
a one-to-one mapping exists between IP address 10.0.0,2 and 10.2.114.13. From the 
perspective of the host system 1230, the host system 1230 recognizes client device A 1205 as 
10.2.114.13. 

5 The network address translation mapping scheme enables the host system 1230 to 

provide the client device access to infomiation maintained by the host system for that 
particular client device. The mapping scheme also enables the user of the client device 1205 
to access user specific information maintained by the host system 1230. Such information 
maintained by the host system 1230 may include, for example, parental control settings, 

10 wallet settings, and personal web page settings. 

Additionally, the network address translation module within the home gateway device 
1215 enables the home gateway device 1215 to use this mapping scheme for multiple client 
devices 1205 over the single communication tunnel 1225 (e.g., by establishing multiple 
L2TP sessions over the single L2TP tunnel). The home gateway device 1215 may process 

15 the mapping scheme for many unique addresses that the home gateway device 1215 senses 
over the network 1210 between the client devices 1205 and the home network device 1215. 
Additionally or alternatively, the home gateway device 1215 may limit the number of 
simultaneous L2TP sessions it allows. 

In this implementation, the client devices typically are TCP/IP enabled and may use 

20 various software components (e.g., Microsoft™ TCP/IP stack) that enable TCP/IP 

communications. When using a NAT module within the home gateway device 1215, the 
client devices 1205 may not need to be PPP enabled. 

Dynamic Host Configuration Protocol 

25 Referring to Fig. 13, in another implementation, the home networking system may be 

implemented using a home gateway device 1315, which includes a Dynamic Host 
Configuration Protocol (DHCP) module 1327 that enables the host system to recognize 
individual client devices (505 from Fig. 5). The home gateway device 1315 also includes an 
L2TP access concentrator 1319 and a TCP/IP module 1323, which facilitate communications 

30 with the host system (530 from Fig. 5). 

In this implementation, the home gateway device 1315 and the host system 530 
typically communicate over a broadband communications link (e.g., xDLS, satellite, and 
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cable) (525 from Fig. 5) such that a continuous connection between the home gateway device 
1315 and the host system 530 is possible. 

Referring to Fig. 14, in one example, when a client device 505 that is DHCP capable 
is started (step 1405) and a determination is made as to whether a connection between the 
home gateway device 1315 and the host system 530 is already established (step 1410). If the 
connection is already established, the client device 505 is assigned an independent Internet 
address by the host system 530 (step 1415). The host-assigned independent address may 
function as both a local address for use on the network (510 from Fig. 5) between the client 
device 505 and the home gateway device 1315, and as an external address for use between 
the client device 505 and the host system 530. Multiple DHCP-capable client devices 505 
may receive independent Internet addresses from the host system 530 using the single 
communication tunnel 525 between the home gateway device 1315 and the host system 530. 

If the connection between the home gateway device 1315 and the host system 530 is 
not already established (step 1410), then the starting of the client device 505 triggers the 
home gateway device 1315 to establish a continuous connection with the host system 530 
(step 1420). Once the connection between the home gateway device 1315 and the host 
system 530 is established, the host system 530 assigns the client device 505 the independent 
IP address (step 1415). 

The described systems, methods, and techniques may be implemented in digital 
electronic cnrcuitry, computer hardware, firmware, software, or in combinations of these 
elements. Apparatus embodying these techniques may include appropriate input and output 
devices, a computer processor, and a computer program product tangibly embodied in a 
machine-readable storage device for execution by a programmable processor. A process 
embodying these techniques may be performed by a programmable processor executing a 
program of instructions to perform desired functions by operating on input data and 
generating appropriate output. The techniques may be implemented in one or more computer 
programs that are executable on a programmable system including at least one programmable 
processor coupled to receive data and instructions from, and to transmit data and instructions 
to, a data storage system, at least one input device, and at least one output device. Each 
computer program may be implemented in a high-level procedural or object-oriented 
programming language, or in assembly or machine language if desired; and in any case, the 
language may be a compiled or interpreted language. Suitable processors include, by way of 
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example,, both, general and special purpose microprocessors. Generally, a processor will 
receive instructions and data from a read-only memory and/or a random access memory. 
Storage devices suitable for tangibly embodying computer program instructions and data 
include all forms of non-volatile memory, including by way of example semiconductor 
memory devices, such as Erasable Programmable Read-Only Memory (EPROM), 
Electrically Erasable Programmable Read-Only Memory (EEPROM), and flash memory 
devices; magnetic disks such as internal hard disks and removable disks; magneto-optical 
disks; and Compact Disc Read-Only Memory (CD-ROM). Any of the foregoing may be 
supplemented by, or incorporated in, specially-designed ASICs (application-specific 
integrated circuits). 

A number of implementations have been described. Nevertheless, it will be 
understood that various modifications may be made without departing from the spirit and 
scope of the claims. For example, advantageous results still could be achieved if steps of the 
disclosed techniques were performed in a different order and/or if components in the 
disclosed systems were combined in a different manner and/or replaced or supplemented by 
other components. Accordingly, other implementations are within the scope of the following 
claims. 
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1 What is claimed is: 

2 1. A system for connecting multiple home-networked client devices to a host 

3 system, wherein the host system assigns independent Internet addresses to the home- 

4 networked client devices, the system comprising: 

5 a home gateway device which includes a communication device to communicate with 

6 the host system over a single communication tunnel established between the home gateway 

7 device and the host system; and 

8 multiple home-networked client devices connected to the home gateway device via a 

9 network and that communicate with the host system through the home gateway device over 

1 0 the single communication tunnel, 

1 1 wherein the system is configured to enable the host system to establish individual 

12 communication sessions with the multiple home-networked client devices over the single 

1 3 communication tunnel and to assign independent Internet addresses to the multiple home- 

14 networked client devices. ■ 

1 2. The system of claim 1 wherein the home gateway device is physically located 

2 in a personal residence. 

1 3 . The system of claim 2 wherein the personal residence is a single family 

2 dwelling. 

1 4. The system of claim 1 wherein the home gateway device and the home- 

2 networked client devices are physically located in a personal residence. 

1 5 . The system of claim 4 wherein the personal residence is a single family 

2 dwelling. 

1 6. The system of claim 2 wherein the home-networked client devices include 

2 wireless client devices that are connected to the home gateway device via a wireless network. 

1 7. The system of claim 6 wherein the wireless client devices operate outside of 

2 the personal residence. 
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1 8, The system of claim 1 wherein the home-networked client devices establish 

2 simultaneous individual communication sessions with the host system over the single 

3 communication tunnel and each home-networked client device is assigned an independent 

4 Internet address by the host systom. 

1 9. The system of claim 1 wherein the host system includes an Internet Service 

2 Provider* 

1 1 0. The system of claim 1 wherein the home gateway device commitnicates with 

2 the multiple home-networked client devices using a first protocol and cotmnunicates with the 

3 host system using a second protocol. 

1 11. The system of claim 1 0 wherein the first protocol and the second protocol are 

2 the same* 

1 12. The system of claim 10 wherein tire second protocol differs from the first 

2 protocol. 

1 13. The system of claim 12 wherein the home gateway device includes one or 

2 more modules that are structured and arranged to convert between the first protocol and the 

3 second protocol. 

1 14. The system of claim 12 wherein: 

2 the home-networked client devices are PPP enabled; 

3 the first protocol is PPPoE; and 

4 the second protocol is L2TP. 

1 15. The system of claim 14 wherein the home gateway device emulates a PPPoE 

2 access concentrator and an L2TP access concentrator. 

1 16. The system of claim 1 wherein Hie communication device includes a modem. 

1 17. The system of claim 16 wherein the communication device includes a cable 

2 modem. 
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1 1 8, The system of claim 1 6 wherein the communication device includes a satellite 

2 modem. 

1 19. The system of claim 1 6 wherein the communication device includes a DSL 

2 modem. 

1 20. The system of claim 1 wherein the multiple home-networked client devices 

2 include client devices having computer software that enable the client devices to interface 

3 with the home gateway device and to communicate with the host system through the home 

4 gateway device, such that the host system is able to recognize independent client devices. 

1 21. The system of claim 20 wherein the independent client devices are recognized 

2 by the host system through the use of unique identifiers assigned to each of the client devices 

3 by the host system during the established communication session. 

1 22. The system of claim 21 wherein the unique identifiers are unique to the client 

2 devices. 

1 23 . The system of claim 2 1 wherein the unique identifiers include independent 

2 Internet addresses. 

1 24. The system of claim 21 wherein the unique identifiers are unique to users of 

2 the client devices. 

1 25. The system of claim 24 wherein at least one of the unique identifiers includes 

2 a unique identifier for a user of the client devices combined with an independent Internet 

3 address assigned to a client device. 

1 26. The system of claim 25 wherein at least one of the unique identifiers for the 

2 user of the client devices includes a screen name. 
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1 * 27. The system of claim 1 wherein the multiple home-networked client devices 

2 are each assigned an independent Internet address by the host system that enables the host 

3 system to recognize a user of a home-networked client device, the user having a unique 

4 identifier that is which combined with the independent Internet address to allow the user 

5 access to individual information maintained by the host system for that user. 

1 28. The system of claim 27 wherein the user having the "unique identifier 

2 combined with the independent Internet address allows the host system to enforce host-based 

3 parental controls. 

1 29. The system of claim 27 wherein the individual information maintained by the j 

2 host system includes wallet information. 

1 30. The system of claim 27 wherein the individual information maintained by the 

2 host system includes calendar information. 

1 31. The system of claim 27 wherein the individual mformation maintained by the 

2 host system includes personalized web page information. 

i 

! 

Hie system of claim 1 wherein the home gateway device includes a personal j 

j 
i 

I 

I 

The system of claim 1 wherein the home gateway device includes a server. | 

I 

The system of claim 1 wherein the network includes a wired network. 

i 

The system of claim 1 wherein the network includes a wireless network. 
The system of claim 1 wherein the network includes a wired and a wireless 

The system of claim 1 wherein the network includes an Ethernet network. 

The system of claim 1 wherein the home gateway device includes a dynamic j 
2 host configuration protocol module. J 
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1 39. The system of claim 1 wherein: 

2 the home gateway device includes: 

3 a dynamic host configuration protocol module; and 

4 an L2TP access concentrator; and 

5 the home-networked client devices communicate with the home gateway device using 

6 the dynamic host configuration protocol module. 

1 40. The system of claim 39 wherein: 

2 the network between the home gateway device and the home-networked client 

3 devices uses the dynamic host configuration protocol module to enable the home gateway 

4 device to assign unique addresses to the home-networked client devices; 

5 the single communication tunnel established between the home gateway device and 

6 the host system is established over a broadband network; and 

7 the dynamic host configuration module is configured to facilitate communications 

8 between the host system and the home-networked client devices to enable the host system to 

9 enforce host-based parental controls. 

1 41. The system of claim 40 wherein the assignment of unique addresses is 

2 performed upon bootup of the home-networked client devices. 

1 42. The system of claim 1 wherein the home gateway device and the multiple 

2 home-networked client devices communicate over the network using DHCP and the multiple 

3 home-networked client devices are each assigned a single address that is used in 

4 communications with the home gateway device and the host system. 
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43. A method for connecting multiple home-networked client devices to a host 
system, wherein the host system assigns independent Internet addresses to the home- 
networked client devices, the method comprising: 

using the home gateway device to receive a request from at least one home- 
networked client device to communicate with the host system, wherein the home-networked 
client device is connected to the home gateway device via a network; 

using the home gateway device to establish communications with the host system 
over a single communication tunnel; 

using the home gateway device to establish with the host system an individual 
communication session over the single communication tunnel, wherein the individual 
communication session is based on an independent Internet address assigned to the home- 
networked client device that requested to communicate with the host system; and 

using the home gateway device to process communications between the home- 
networked client device and the host system. 

44. The method of claim 43 further comprising physically locating the home 
gateway device in a personal residence such that the request is received in the personal 
residence* 

45. The method of claim 44 wherein the personal residence is a single family 
dwelling such that the request is received in the single family dwelling. 

46. The method of claim 43 further comprising physically locating the home 
gateway device and the home-networked client devices in a personal residence such that the 
request is received in the personal residence. 

47. The method of claim 46 wherein the personal residence is a single family 
dwelling such that the request is received in the single family dwelling. 
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1 48. The method of claim 43 further comprising: 

2 using the home gateway device to establish with the host system multiple 

3 simultaneous individual communication sessions over the single communication tunnel, 

4 wherein the multiple simultaneous individual communication sessions are each based on an 

5 independent Internet address assigned to the home-networked client devices that request to 

6 communicate with the host system; and 

7 using the home gateway device to process communications between the home- 

8 networked client devices and the host system. 

1 49. The method of claim 43 wherein the host system includes an Internet Service 

2 Provider. 

1 50. The method of claim 43 wherein using the home gateway device to process 

2 communications between the home-networked client device and the host system includes: 

3 using the home gateway device to communicate with the home-networked client 

4 device using a first protocol; and 

5 using the home gateway device to communicate with the host system using a second 

6 protocol. 

1 51. The method of claim 50 wherein the first protocol and the second protocol are 

2 the same. 

1 52. The method of claim 50 wherein the second protocol differs from the first 

2 protocol. 

1 53. The method of claim 50 wherein the first protocol includes PPPoE and the 

2 second protocol includes L2TP. 

1 54. The method of claim 53 wherein the home gateway device includes a PPPoE 

2 access concentrator and an L2TP access concentrator. 
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1 55. The method of claim 50 wherein using the home gateway device to process 

2 communications includes: 

3 removing a first header from the communications received from the home-networked 

4 client device destined for the host system; 

5 adding a second header to the communications; and 

6 sending the communications with the second header to the host system. 

1 56. The method of claim 55 wherein using the home gateway device to process 

2 communications includes: 

3 removing a third header from the communications received from the host system 

4 destined for the home-networked client device; 

5 adding a fourth header to the communications; and 

6 sending the communications with the fourth header to the home-networked client 

7 device. 

1 . 57. The method of claim 43 wherein the home gateway device includes a dynamic 

2 host configuration protocol module. 

1 58. The method of claim 43 wherein using the home gateway device to process 

2 communications between the home-networked client device and the host system includes: 

3 using the home gateway device to communicate with the home-networked client 

4 device using DHCP; and 

5 using the home gateway device to communicate with the host system using L2TP. 

1 59. The method of claim 43 wherein; 

2 using the home gateway device to establish communications with the host system 

3 includes establishing communications with the host system over a broadband network; and 

4 using the home gateway device to process communications between the home- 

5 networked client device and the host system includes the home gateway device using the 

6 host-assigned independent Internet address to communicate over the network with the home- 

7 networked client device. 



32 



WO 01/71977 



PCT/US01/08559 



1 60. The method of claim 59 wherein the independent Internet address is assigned 

2 to the home-networked client device upon bootup. 

1 6 1 . A method for connecting multiple home-networked client devices to a host 

2 system,, wherein the host system assigns independent Internet addresses to the home- 

3 networked client devices, the method comprising: 

4 using the host system to receive a request for an individual communication session 

5 with a home-networked client device; 

6 using the host system to establish communications with the home gateway device 

7 over a single communication tunnel; 

8 using the host system to establish with the home gateway device the individual 

9 communication session over the single communication tunnel, wherein establishing the 

10 individual communication session includes assigning an independent Internet address to the 

1 1 home-networked client device that requested to communicate with the host system; and 

1 2 communicating between the host system and the home-networked client device 

13 through the home gateway device over the individual communication session. 

1 62. The method of claim 61 further comprising physically locating the home 

2 gateway device in a personal residence such that the request is received in the personal 

3 residence, 

1 63. The method of claim 62 wherein the personal residence is a single family 

2 dwelling such that the request is received in the single family dwelling. 

1 64. The method of claim 61 further comprising physically locating the home 

2 gateway device and the home-networked client devices in a personal residence such that the 

3 request is received in the personal residence* 

1 65. The method of claim 64 wherein the personal residence is a single family 

2 dwelling such that the request is received in the single family dwelling. 
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1 66. The method of claim 61 further comprising: 

2 using the host system to establish multiple simultaneous individual communication 

3 sessions with the home gateway device over the single communication tunnel, wherein 

4 establishing the multiple simultaneous individual communication sessions includes assigning 

5 an independent Internet address to each home-networked client device that requests to 

6 communicate with the host system; and 

7 communicating between the host system and the home-networked client devices 

8 through the home gateway device over the multiple simultaneous individual communication 

9 sessions. 

1 67, The method of claim 66 further comprising having the host system use the 

2 assigned independent Internet address to communicate individual information maintained by 

3 the host system to the home-networked client devices. 

1 68. The method of claim 67 wherein the individual iixformation includes host- 

2 based parental controls. 

1 • 69. The method of claim 67 wherein the individual information includes wallet 

2 information. 

1 70. The method of claim 67 wherein the individual information includes calendar 

2 information. 

1 71. The method of claim 67 wherein the individual information includes 

2 personalized web page information. 

1 72. The method of claim 61 wherein the host system includes an Internet Service 

2 Provider. 
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73. A system for connecting multiple home-networked client devices to a host 
system, wherein the host system assigns independent Internet addresses to the home- 
networked client devices, the system comprising: 

a home gateway device which includes a communication device to communicate with 
the host system over a single communication tunnel established between the home gateway 
device and the host system, wherein the home gateway device includes a network address 
translation module; and 

multiple home-networked client devices connected to the home gateway device via a 
network and that communicate with the host system through the home gateway device over 
the single communication tunnel, 

wherein the system is configured to enable the host system to establish individual 
communication sessions with the multiple home-networked client devices over the single 
communication tunnel and to assign independent Internet addresses to the multiple home- 
networked client devices. 

74. The system of claim 73 wherein the home gateway device is physically 
located in a personal residence. 

75. The system of claim 74. wherein the personal residence is a single family 
dwelling. 

76. The system of claim 73 wherein the home gateway device and the home- 
networked client devices are physically located in a personal residence. 

77. The system of claim 76 wherein the personal residence is a single family 
dwelling. 

78. Hie system of claim 74 wherein the home-networked client devices include 
wireless client devices that are connected to the home gateway device via a wireless network. 

79. The system of claim 78 wherein the wireless client devices operate outside of 
the personal residence. 
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80. The system of claim 73 wherein the home-networked client devices establish 
simultaneous individual communication sessions with the host system over the single 
communication tunnel and each home-networked client device is assigned an independent 
internet address by the host system. 

81. The system of claim 73 wherein the host system includes an Internet Service 
Provider. 

82. The system of claim 73 wherein the network address translation module 
includes a port-based network address translation module. 

83. The system of claim 73 wherein the network address translation module 
includes an address-based network address translation module. 

84. The system of claim 73 wherein the home gateway device communicates with 
the multiple home-networked client devices using a first protocol and communicates with the 
host system using a second protocol. 

85. The system of claim 84 wherein the first protocol and the second protocol are 
the same. 

86. The system of claim 84 wherein the second protocol differs from the first 
protocol. 

87. The system of claim 84 wherein: 
the first protocol is TCP/IP; and 

the second protocol is L2TP. 

88. The system of claim 87 wherein the home gateway device includes: 
a network address translation module; and 

an L2TP access concentrator. 

89. Tlie system of claim 88 wherein the network address translation module 
includes a port-based network address translation module. 
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1 90. The system of claim 88 wherein the network address translation module 

2 includes an address-based network address translation module. 

1 91 . The system of claim 90 wherein the network address translation module 

2 interfaces with the home-networked client devices and the host system to route 

3 communications between the host system to the home-networked client devices by 

4 translating the independent Internet addresses assigned by the host system to the home- 

5 networked client devices and local addresses belonging to Hie home-networked client devices 

6 that are used on the network between the home gateway device and the home-networked 

7 client devices. 

1 92. The system of claim 91 wherein the multiple home-networked client devices 

2 are recognized by the host system as independent client devices through the use of unique 

3 identifiers. 

1 93. A method for connecting multiple home-networked client devices to a host 

2 system, wherein the host system assigns independent Internet addresses to the home- 

3 networked client devices, the method comprising: 

4 using the home gateway device to receive a request from at least one home- 

5 networked client device to communicate with the host system, wherein the home-networked 

6 client device is connected to the home gateway device via a network; 

7 using the home gateway device to establish communications with the host system 

8 over a single comimmication tunnel; 

9 using the home gateway device to establish an individual communication session with 

I o the host system over the single communication tunnel, wherein the individual communication 

I I session is based on an independent Internet address assigned to the home-networked client 

12 device that requested to communicate with the host system; and 

13 using the home gateway device to process communications between the home- 

14 networked client device and the host system by mapping the independent Internet address 

15 assigned by the host system for the home-networked client device to a local address used 

16 between the home gateway device and the home-networked client device. 
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1 94. The method of claim 93 further comprising physically locating the home 

2 gateway device in a personal residence such that the request is received in the personal 

3 residence. 

1 95. The method of claim 94 wherein the personal residence is a single family 

2 dwelling such that the request is received in the single family dwelling. 

1 96. The method of claim 93 further comprising physically locating the home 

2 gateway device and the home-networked client devices in a personal residence such that the 

3 request is received in the personal residence. 

1 97. The method of claim 96 wherein the personal residence is a single family 

2 dwelling such that the request is received in the single family dwelling. 

1 98. The method of claim 93 further comprising: 

2 using the home gateway device to establish with the host system multiple 

3 simultaneous individual communication sessions over the single communication tunnel, 

4 wherein the multiple simultaneous individual communication sessions are each based on an 

5 independent Internet address assigned to the home-networked client devices that request to 

6 communicate with the host system; and 

7 using the home gateway device to process communications between the home- 

8 networked client devices and the host system. 

1 99. The method of claim 93 wherein the host system includes an Internet Service 

2 Provider. 

1 100. The method of claim 93 wherein using the home gateway device to process 

2 communications between the home-networked client device and the host system includes: 

3 using the home gateway device to communicate with the home-networked client 

4 device using a first protocol; and 

5 using the home gateway device to communicate with the host system using a second 

6 protocol. 
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101. The method of claim 1 00 wherein the first protocol and the second protocol 
are the same. 

102. The method of claim 100 wherein the second protocol differs from the first 
protocol 

1 03. The method of claim 1 00 wherein the first protocol includes TCP/IP and the 
second protocol includes L2TP. 

104. The method of claim 93 wherein using the home gateway device to process 
communications between the home-networked client device and the host system includes: 

removing a first header including the local address from the communications received 
from the home-networked client device destined for the host system; 

adding a second header including the independent Internet address to the 
communications; and 

sending Hie communications with the second header to the host system, 

105. The method of claim 104 wherein using the home gateway device to process 
communications between the home-networked client device and the host system includes: 

removing a third header including the independent Internet address from the 
communications received from the host system destined for the home-networked client 
device; 

adding a fourth header including the local address; and 

sending the communications with the fourth header to the home-networked client 

device. 
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1 1 06. A method for connecting multiple home-networked client devices to a host 

2 system, wherein the host system assigns independent Internet addresses to the home- 

3 networked client devices, the method comprising: 

4 using the host system to receive a request for an individual coxnmunication session 

5 with a home-networked client device; 

6 using the host system to establish communications with the home gateway device 

7 over a single communication tunnel; 

8 using the host system to establish with the home gateway device the individual 

9 communication session over the single communication tunnel, wherein establishing the 

10 individual communication session includes assigning an independent Internet address to the 

1 1 home-networked client device that requested to communicate with the host system; and 

1 2 communicating between the host system and the home-networked client device 

13 through the home gateway device over the individual communication session, wherein the 

14 independent Internet address is mapped to a local address. 

1 1 07. The method of claim 1 06 further comprising physically locating the home 

2 gateway device in a personal residence such that the request is received in the personal 

3 residence. 

1 108. The method of claim 1 07 wherein the personal residence is a single family 

2 dwelling such that the request is received in the single family dwelling. 

1 109. The method of claim 106 further comprising physically locating the home 

2 gateway device and the home-networked client devices in a personal residence such that the 

3 request is received in the personal residence. 

1 110. The method of claim 109 wherein the personal residence is a single family 

2 dwelling such that the request is received in the single family dwelling. 
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1 111. The method of claim 1 06 further comprising: 

2 using Hie host system to establish multiple simultaneous individual communication 

3 sessions with the home gateway device over the single communication tunnel, wherein 

4 establishing the multiple simultaneous individual communication sessions includes assigning 

5 an independent Internet address to each home-networked client device that requests to 

6 communicate with the host system; and 

7 communicating between the host system and the home-networked client devices 

8 through the home gateway device over the multiple simultaneous individual communication 

9 sessions, wherein each independent Internet address is mapped to a local address assigned to 
1 0 each home-networked client device, 

1 1 12. The method as in claim 111 further comprising having the host system use the 

2 assigned independent Internet address to communicate individual information maintained by 

3 the host system to the home-networked client devices. 

1 113. The method as in claim 112 wherein Hie individual information includes host- 

2 based parental controls. 

1 1 14. The method as in claim 1 12 wherein the individual information includes. 

2 wallet information. 

1 115. The method as in claim 112 wherein the individual information includes 

2 calendar information. 

1 116. The method as in claim 112 wherein the individual information includes 

2 personalized web page information. 

1 117. The method of claim 1 06 wherein the host system includes an Internet Service 

2 Provider. 
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